草庐IT

PHP preg_match_all 搜索和替换

全部标签

ruby - 如何使用部分字符串搜索数组并返回索引?

我想使用部分字符串搜索数组,然后获取找到该字符串的索引。例如:a=["Thisisline1","Wehaveline2here","andfinallyline3","potato"]a.index("potato")#thisreturns3a.index("Wehave")#thisreturnsnil使用a.grep将返回完整的字符串,使用a.any?将返回正确的true/false语句,但都不会返回匹配的索引找到了,或者至少我不知道该怎么做。我正在编写一段代码,该代码读取文件、查找特定header,然后返回该header的索引,以便它可以将其用作future搜索的偏移量。如果

ruby - 如何替换字符串中的字符

我有一个方法可以用来替换字符串中的字符:defcomplexity_level_tworeplacements={'i'=>'eye','e'=>'eei','a'=>'aya','o'=>'oha'}word="Cocoa!55"word_arr=word.split('')results=[]word_arr.each{|char|ifreplacements[char]!=nilresults.push(char.to_s.gsub!(replacements[char]))elseresults.push(char)end}end我想要的字符串输出应该是:Cohacohaa!5

ruby-on-rails - 自动完成搜索的 Rails 实现

我不确定如何为我的搜索功能添加自动完成表单。"get"do%>nil%>我有一个具有自定义操作的Controllerdefquery@users=Search.user(params[:query])@article=Search.article(params[:query])end模型如下:defself.user(search)ifsearchUser.find(:all,:conditions=>['first_nameLIKE?',"%#{search}%"])elseUser.find(:all)endenddefself.article(search)ifsearchArt

Ruby:如何替换文件中的文本?

下面的代码是xml文件中的一行:455360226如何使用ruby​​将2个标签之间的数字替换为另一个数字? 最佳答案 不可能一步修改文件内容(至少我不知道,当文件大小改变时)。您必须读取文件并将修改后的文本存储在另一个文件中。replace="100"infile="xmlfile_in"outfile="xmlfile_out"File.open(outfile,'w')do|out|out\d+/,"#{replace}")end或者您将文件内容读入内存,然后用修改后的内容覆盖文件:replace="100"filename=

ruby - 查找和替换多个单词

我经常需要在文件中进行多次替换。为了解决这个问题,我创建了两个文件old.text和new.text。第一个包含必须找到的单词列表。第二个包含应该替换那些单词的列表。我的所有文件都使用UTF-8并使用各种语言。我已经构建了这个脚本,我希望它可以进行替换。首先,它一次读取old.text一行,然后用new.text文件中的相应单词替换input.txt中该行的单词。#!/bin/shnumber=1whilereadlinefromoldwordsdoecho$linefromoldwordslinefromnewwords=$(sed-n'$numberp'new.text)awk'{

ruby-on-rails - 用 Ruby 替换文件中的单词

我是Ruby的新手,我一直在尝试替换文件中的单词。其代码如下:File.open("hello.txt").eachdo|li|if(li["install"])li["install"]="latest"puts"thegoalstatesettoinstall,changedtolatest"endend虽然puts中的消息被打印一次,但该文件的该行中的单词不会更改为“最新”。谁能告诉我这里出了什么问题?谢谢 最佳答案 您还需要写回文件。File.open不带任何参数打开文件以供读取。你可以试试这个:#loadthefileas

ruby-on-rails - 在具有 enum_attr 的记录上调用 .all 时参数数量错误

MODEL1有一个account_type,所以使用gem'enumerated_attributes',我制作了这样的模型:classMODEL1我不明白的奇怪的事情是,当我像这样查询任意MODEL1的种子时(这是我在ruby​​mine控制台中运行follwing命令时的错误,但在rakedb期间会发生同样的2for1错误:种子):MODEL1.all.sample和MODEL1.all我明白了:DealerLoad(0.3ms)SELECT"MODEL1".*FROM"MODEL1S"ArgumentError:wrongnumberofarguments(2for1)from/

ruby - 为什么 `Symbol#match` 的行为与 `String#match` 和 `Regexp#match` 不同?

String#match和Regexp#match在匹配成功时返回一个MatchData:"".match(//)#=>#//.match("")#=>#//.match(:"")#=>#但是Symbol#match返回匹配位置(如String#=~)::"".match(//)#=>0为什么Symbol#match表现不同?有用例吗? 最佳答案 我将其报告为Ruby核心中的错误:https://bugs.ruby-lang.org/issues/11991.让我们看看他们会怎么说。更新被质疑的行为似乎是一个错误。似乎从Ruby2.

ruby-on-rails - ActionMailer HTML 编码 hell - 特殊字符替换为垃圾

我有UTF-8字符串:Website•Facebook那是中间的一颗子弹又名•或0xE20x800xA2此值已正确存储在数据库中,并使用默认设置使用Rails3和ruby​​1.9.3正确显示在屏幕上。我正在尝试通过HTML电子邮件发送此邮件,但是当一切都说完之后,接收端看到的是垃圾:这背后的代码很简单,我有一个ActionMailer子类(默认使用UTF-8)设置以在布局中发送带有UTF-8内容编码的HTML电子邮件:email.html.erb布局文件:"all"%>内容使用与呈现网页相同的View,重要的一行是:我已经尝试了很多很多force_encoding的排列,e

ruby , `match' : invalid byte sequence in UTF-8

我对UTF-8编码有一些问题。我在这里阅读了一些帖子,但它仍然无法正常工作。这是我的代码:#!/bin/envruby#encoding:utf-8defdeterminefile=File.open("/home/lala.txt")file.eachdo|line|puts(line)type=line.match(/DOG/)puts('aaaaa')iftype!=nilputs(type[0])breakendendend这是我文件的前3行:;?lalalalal60000065535-1362490443-0000006334-0000018467-0000000041en